//定制请求的实例

//导入axios  npm install axios
import axios from 'axios';

import { ElMessage } from 'element-plus'

//定义一个变量,记录公共的前缀  ,  baseURL
// const baseURL = 'http://localhost:8080';
const baseURL = '/api';
const instance = axios.create({ baseURL })



import router from '@/router';
import { useTokenStore } from '@/stores/token';
//添加响应拦截器
instance.interceptors.response.use(
    result => {
        //判断业务状态码
        if (result.data.code == 0) {
            return result.data;
        }
        //操作失败
        // alert(result.data.msg ? result.data.msg : "服务异常")
        ElMessage.error(result.data ? result.data : "服务异常")
        return Promise.reject(result.data);
    },
    err => {
        //判断响应状态码，如果为401则未登录，提示请登录并跳转登录页面
        if (err.response.status == 401) {
            ElMessage.error("请先登录");
            router.push("/login");
        } else {
            ElMessage.error("服务异常");
        }
        return Promise.reject(err);//异步的状态转化成失败的状态
    }
)

//请求拦截器（token）
instance.interceptors.request.use(
    (config) => {
        //请求前回调
        //添加token
        let tokenStore = useTokenStore();
        //判断是否存在token
        if (tokenStore.token) {
            config.headers.Authorization = tokenStore.token
        }
        return config
    },
    (err) => {
        //请求错误的回调
        return Promise.reject(err)
    }
)



export default instance;